//入口文件
import Vue from 'vue'
//1.1导入路由的包
import VueRouter from 'vue-router'
//1.2安装路由
Vue.use(VueRouter)

//注册 vuex
import Vuex from 'vuex'
Vue.use(Vuex)

//每次刚进入 网站,肯定会 调用 main.js 在刚调用的时候,先从本地存储中,把购物车的数据读出来,放到store中
var car=JSON.parse(localStorage.getItem('car')||'[]')

var store=new Vuex.Store({
  state:{ //this.$store.state.***
    car: car //将 购物车中的商品的数据,用一个数组存储起来,在car数组中,存储一些商品的对象,可以暂时将这个商品对象,设计成这个样子
    // {id:商品的ID, count: 要购买的数量, price:商品的单价, selected: false }
  },
  mutations:{ //this.$store.commit('方法名称','按需传递唯一的参数')
    addToCar(state,goodsinfo){
      //点击加入购物车,把商品信息,保存到store 中的car 上
      //分析:
      //1.如果购物车中,之前就已经有这个对应的商品里,那么,只需要更新数量
      //2.如果没有,则直接把商品数据,push到 car中即可

      //假设 在购物车中,没有找到对应的商品
      var flag=false

      state.car.some(item=>{
        if(item.id==goodsinfo.id){
          item.count+=parseInt(goodsinfo.count)
          flag=true
          return true
        }
      })
      
      //如果最终,循环完毕,得到的 flag还是false,则把商品数据直接 push 到购物车中
      if (flag===false){
        state.car.push(goodsinfo)
      }

      //当更新car 之后,把car数组,存储到 本地的 localStorage中
      localStorage.setItem('car',JSON.stringify(state.car))
    },
    updateGoodsInfo(state,goodsinfo){
      //修改购物车中商品的数量值
      //分析:
      state.car.some(item=>{
        if(item.id==goodsinfo.id){
          item.count=parseInt(goodsinfo.count)
          return true
        }
      })
      //当修改完商品的数量 之后,把最新的car数组,存储到 本地的 localStorage中
      localStorage.setItem('car',JSON.stringify(state.car))
    },
    removeFormCar(state,id){
      //根据ID,从 store 中的购物车中 删除对应的那条商品数据
      state.car.some((item,i)=>{
        if(item.id==id){
          state.car.splice(i,1)
          return true
        }
      })
      //将删除完毕后的,把最新的car数组,存储到 本地的 localStorage中
      localStorage.setItem('car',JSON.stringify(state.car))
    },
    updateGoodsSelected(state,info){
      state.car.some(item=>{
        if(item.id==info.id){
          item.selected=info.selected
        }
      })
      //将最新的购物车商品的状态,存储到 本地的 localStorage中
      localStorage.setItem('car',JSON.stringify(state.car))
    }
  },
  getters:{ //this.$store.getters.***
    //相当于 计算属性,也相当于 filters
    getAllCount(state){
      var c=0;
      state.car.forEach(item=>{
        c+=item.count
      })
      return c
    },
    getGoodsCount(state){
      var o ={}
      state.car.forEach(item => {
        o[item.id]=item.count
      })
      return o
    },
    getGoodsSelected(state){
      //创建一个把开关和商品id绑定起来的对象{id:Boolean}
      var o={}
      state.car.forEach(item=>{
        o[item.id]=item.selected
      })
      return o
    },
    getGoodsCountAndAmount(state){
      var o={
        count:0, //勾选的数量
        amount:0 //勾选的总价
      }
      state.car.forEach(item=>{
        if(item.selected){
          o.count+=item.count
          o.amount+=item.price*item.count
        }
      })
      return o
    }
  }
})

// 导入格式化时间的插件
import moment from 'moment'
// 定义全局的过滤器
Vue.filter('dateFormat', function (dataStr, pattern = "YYYY-MM-DD HH:mm:ss") {
  return moment(dataStr).format(pattern)
})

//2.1导入 vue-resource
import VueResource from 'vue-resource'
//2.2安装 vue-resource
Vue.use(VueResource)
//设置请求的根路径
Vue.http.options.root = 'http://www.liulongbin.top:3005';
//全局设置 post 时候表单数据格式组织形式 application/x-www-form-urlencoded
Vue.http.options.emulateJSON = true;


//导入 MUI 的样式
import './lib/mui/css/mui.min.css'
import './lib/mui/css/icons-extra.css'


//按需导入 Mint-UI 中的组件
// import { Header, Swipe, SwipeItem, Button, Lazyload } from 'mint-ui';
import 'mint-ui/lib/style.css'
// Vue.component(Header.name, Header)
// Vue.component(Swipe.name, Swipe)
// Vue.component(SwipeItem.name, SwipeItem)
// Vue.component(Button.name, Button)
// Vue.use(Lazyload);
import MintUI from 'mint-ui'
Vue.use(MintUI)

//安装 图片预览插件
import VuePreview from 'vue-preview'
Vue.use(VuePreview)




//1.3导入自己的 router.js 路由模块
import router from './router.js'


//导入 App 根组件
import app from './App.vue'

var vm=new Vue({
  el:'#app',
  render: c=> c(app),
  router,   //1.4 挂在路由对象到 VM 实例上
  store    //挂载 store 状态管理对象
})